In [ ]:
from pyqgl2.main import compile_function, qgl2_compile_to_hardware
from pyqgl2.test_cl import create_default_channelLibrary
from pyqgl2.qreg import QRegister
from QGL import plot_pulse_files, ChannelLibrary
import numpy as np
In [ ]:
toHW = True
In [ ]:
create_default_channelLibrary(toHW, True)
# Alternatively could load an existing library, or create one here; see the 'AllXY' notebook
In [ ]:
# For QGL2, use a QRegister, not a QGL Qubit
q = QRegister(1)
In [ ]:
#from pyqgl2.ast_util import NodeError
#from pyqgl2.debugmsg import DebugMsg
#DebugMsg.set_level(1)
#NodeError.MUTE_ERR_LEVEL = NodeError.NODE_ERROR_NONE
In [ ]:
# Insert proper path to QGL2 source and name of qgl2main if not so marked
# Here we compile the named function in the named file from QGL2 to QGL1 and return the new function
In [ ]:
tCalR = 2 # calRepeats
cpmgNumPulses = [0, 2, 4, 6]
cpmgSpacing = 500e-9
qgl1MainFunc = compile_function("../src/python/qgl2/basic_sequences/Decoupling.py", "CPMG",
(q, cpmgNumPulses, cpmgSpacing, tCalR))
In [ ]:
# Now run the QGL1 function, producing a list of sequences
seqs = qgl1MainFunc()
In [ ]:
if toHW:
from qgl2.basic_sequences.helpers import delay_descriptor, cal_descriptor
axis_desc = [
# NOTE: numPulses is not a numpy array, so cannot multiply by a float
# But thankfully, np.array(np.array) = np.array so this is always a good move here.
delay_descriptor(cpmgSpacing * np.array(cpmgNumPulses)),
cal_descriptor(('qubit',), tCalR)
]
metaFileName = qgl2_compile_to_hardware(seqs, filename="CPMG/CPMG", axis_descriptor=axis_desc)
print(f"Generated sequence details in '{metaFileName}'")
# Plot the sequences
p = plot_pulse_files(metaFileName)
# Explicitly display the graph which fails to auto-draw in some cases
display(p)
else:
from QGL.Scheduler import schedule
from IPython.lib.pretty import pretty
print(pretty(schedule(seqs)))